package com.cy.demo1.service.impl;

import com.cy.demo1.entity.User;
import com.cy.demo1.mapper.UserMapper;
import com.cy.demo1.service.IUserService;
import com.cy.demo1.service.ex.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.DigestUtils;

import java.util.Date;
import java.util.Locale;
import java.util.UUID;

/**
 * 用户模块业务层实现类
 */
//@Service：将当前类的对象交给Spring来管理，自动创建对象以及对象的维护
@Service
public class UserServiceImpl implements IUserService {
    @Autowired
    private UserMapper userMapper;
    @Override
    public void reg(User user) {
        //通过user参数来获取传递过来的username
        String username = user.getUsername();
        //调用findByUsername(username)判断用户是否被注册过
        User result = userMapper.findByUsername(username);
        //判断结果集是否不为null则抛出用户名被占用的异常
        if (result != null){
            throw  new UsernameDuplicatedException("用户名被占用");
        }

        //密码加密处理的实现 md5算法

        //串加密码加串 交给md5加密 加载三次 串：盐值=随机字符串
        String oldPassword = user.getPassword();
        //获取盐值（随机生成）
        String salt = UUID.randomUUID().toString().toUpperCase();
        //补全数据盐值的记录
        user.setSalt(salt);
        //将密码和盐值作为整体进行加密处理,忽略原有密码强度提升数据的安全性
        String md5Password = getMd5Password(oldPassword, salt);
        //将加密之后的密码重新不全设置到user对象中
        user.setPassword(md5Password);
        //补全数据 is_delete 设置成0
        user.setIsDelete(0);
        //补全数据 4个日志字段信息
        user.setCreatedUser(user.getUsername());
        user.setModifiedUser(user.getUsername());
        Date date =new Date();
        user.setCreatedTime(date);
        user.setModifiedTime(date);
        //执行注册业务功能的实现（row==1）
        Integer rows = userMapper.insert(user);
        if (rows != 1){
            throw new InsertException("在用户注册过程中产生了未知的异常");
        }
    }

    @Override
    public User login(String username, String password) {
        //根据用户名称来查询用户数据是否存在，如不在则抛出异常
        User result = userMapper.findByUsername(username);
        if (result == null){
            throw  new UserNotFoundException("用户数据不存在");
        }
        //检测用户密码是否匹配
        // 1先获取数据库中的加密之后的密码
        String oldPassword = result.getPassword();
        //2和用户传递后的密码进行比较
        //2.1先获取盐值：上一次注册时自动生成的盐值
        String salt = result.getSalt();
        //2.2将用户的密码用相同的md5算法规则进行加密
        String newMd5Password = getMd5Password(password,salt);
        //将密码进行比较
        if (!newMd5Password.equals(oldPassword)){
            throw  new PasswordNotMatchException("用户密码错误");
        }
        //判断is_delete字段的值是否唯一，唯1标识被标记为删除
        if (result.getIsDelete() == 1){
            throw new UserNotFoundException("用户数据不存在");
        }
        //调用mapper层的find方法来查询用户的数据 ，提升了系统性能
        User user =new User();
        user.setUid(result.getUid());
        user.setUsername(result.getUsername());
        //返回有用户的头像
        user.setAvatar(result.getAvatar());
        //将当前的用户数据返回，返回的数据是为了辅助其他页面做数据展示使用（uid,username,avater）
        return user;
    }

    @Override
    public void changePassword(Integer uid, String username, String oldPassword, String newPassword) {
        User result = userMapper.findByUid(uid);
        if(result == null || result.getIsDelete() == 1){
            throw  new UserNotFoundException("用户数据不存在");
        }
        //原始密码和数据库密码比较
         String oldMd5Password = getMd5Password(oldPassword, result.getSalt());
        if (!result.getPassword().equals(oldMd5Password)){
            throw new PasswordNotMatchException("密码错误");
        }
        //将新的密码设置到数据库中，将新的密码进行加密再去更新
        String newMd5Password = getMd5Password(newPassword, result.getSalt());
        Integer rows = userMapper.updatePasswordByUid(uid, newMd5Password, username, new Date());
        if (rows != 1){
            throw new UpdateException("更新数据产生的未知异常");
        }
    }

    @Override
    public User getByUid(Integer uid) {
        User result = userMapper.findByUid(uid);
        if(result == null || result.getIsDelete() == 1){
            throw new UserNotFoundException("用户数据不存在");
        }
        User user = new User();
        user.setUsername(result.getUsername());
        user.setPhone(result.getPhone());
        user.setEmail(result.getEmail());
        user.setGender(result.getGender());
        return user;
    }

    /**
     *User对象中的数据phone email gender 手动将 uid username 封装
     *
     */
    @Override
    public void changeInfo(Integer uid, String username, User user) {
        User result = userMapper.findByUid(uid);
        if(result == null || result.getIsDelete() == 1){
            throw new UserNotFoundException("用户数据不存在");
        }
        user.setUid(uid);
        //user.setUsername(username);
        user.setModifiedUser(username);
        user.setModifiedTime(new Date());

        Integer rows = userMapper.updateInfoByUid(user);
        if(rows != 1){
            throw new UpdateException("更新时数据产生未知的异常");
        }
    }

    @Override
    public void changeAvatar(Integer uid, String avatar, String username) {
        //查询当前的用户数据是否存在

        User result = userMapper.findByUid(uid);
        if(result ==null || result.getIsDelete() == 1){
            throw new UserNotFoundException("用户数据不存在");
        }
        Integer rows = userMapper.updateAvatarByUid(uid, avatar, username, new Date());
        if(rows != 1){
            throw new UpdateException("更新用户头像产生未知的异常");
        }
    }

    /**
     * md5算法加密
     */
    private String getMd5Password(String password, String salt){
        //md5加密算法方法的调用(3次)
        for (int i = 0; i < 3; i++) {
            password = DigestUtils.md5DigestAsHex((salt + password + salt).getBytes()).toUpperCase();
        }
        //返回加密之后的密码
         return password;

    }
}
